package de.mnit.basis.daten.struktur.ordnen;

import de.mnit.basis.daten.struktur.ordnen.algo.Gnomesort;
import de.mnit.basis.daten.struktur.ordnen.algo.Mergesort;
import de.mnit.basis.fehler.Fehler;

/**
 * @author Michael Nitsche
 * 26.11.2010	Erstellt
 */
public class Sortieren {

	private static final Gnomesort	gnome	= new Gnomesort();
	private static final Mergesort	merge	= new Mergesort();


	public static void sortieren(S_Sortierbar<?> tab, int... nach) {
		Fehler.objekt.wenn_Null(tab);
		if(nach==null || nach.length==0)
			nach=new int[]{1};
		for(int i : nach)
			Fehler.zahl.wenn_Ausserhalb(1, tab.gBreite(), Math.abs(i));

		if(tab.gLaenge() <= 10) // Macht aber nur sehr wenig aus. Evtl. macht diese Abfrage schon das Plus kaputt!
			gnome.sortieren(tab, nach);
		else
			merge.sortieren(tab, nach);
		return;
	}

}
